python中@classmethod @staticmethod区别

您所在的位置:网站首页 @classmethod @staticmethod区别 python中@classmethod @staticmethod区别

python中@classmethod @staticmethod区别

2024-03-15 12:43| 来源: 网络整理| 查看: 265

Python中3种方式定义类方法, 常规方式, @classmethod修饰方式, @staticmethod修饰方式.

class A(object): def foo(self, x): print("executing foo(%s,%s)" % (self, x)) print('self:', self) @classmethod def class_foo(cls, x): print("executing class_foo(%s,%s)" % (cls, x)) print('cls:', cls) @staticmethod def static_foo(x): print("executing static_foo(%s)" % x) a = A() 1.定义方式

普通的类方法foo()需要通过self参数隐式的传递当前类对象的实例。 @classmethod修饰的方法class_foo()需要通过cls参数传递当前类对象。@staticmethod修饰的方法定义与普通函数是一样的。

self和cls的区别不是强制的,只是PEP8中一种编程风格,self通常用作实例方法的第一参数,cls通常用作类方法的第一参数。即通常用self来传递当前类对象的实例,cls传递当前类对象。

2.绑定对象 foo方法绑定对象A的实例,class_foo方法绑定对象A,static_foo没有参数绑定。 >>> print(a.foo) >>> print(a.class_foo) > >>> print(a.static_foo) 3.调用方式

foo可通过实例a调用,类对像A直接调用会参数错误。

>>> a.foo(1) executing foo(,1) self: >>> A.foo(1) Traceback (most recent call last): File "", line 1, in TypeError: foo() missing 1 required positional argument: 'x'

但foo如下方式可以使用正常,显式的传递实例参数a。

>>> A.foo(a, 1) executing foo(,1) self:

class_foo通过类对象或对象实例调用。

>>> A.class_foo(1) executing class_foo(,1) cls: >>> a.class_foo(1) executing class_foo(,1) cls:

static_foo通过类对象或对象实例调用。

>>> A.static_foo(1) executing static_foo(1) >>> a.static_foo(1) executing static_foo(1) 4.继承与覆盖普通类函数是一样的。 class B(A): pass b = B() b.foo(1) b.class_foo(1) b.static_foo(1) # executing foo(,1) # self: # executing class_foo(,1) # cls: # executing static_foo(1)

问题:@staticmethod修饰的方法函数与普通的类外函数,为什么不直接使用普通函数?@staticmethod是把函数嵌入到类中的一种方式,函数就属于类,同时表明函数不需要访问这个类。通过子类的继承覆盖,能更好的组织代码。



【本文地址】


今日新闻


推荐新闻


CopyRight 2018-2019 办公设备维修网 版权所有 豫ICP备15022753号-3